<%--
  Created by IntelliJ IDEA.
  User: 494418174
  Date: 2020/2/28 0028
  Time: 16:06
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" href="/favicon.ico">
    <link rel="stylesheet" href="/layui/css/layui.css">
    <link rel="stylesheet" href="/layui_ext/dtree/dtree.css">
    <link rel="stylesheet" href="/layui_ext/dtree/font/dtreefont.css">
</head>
<body class="childrenBody">
<!-- 搜索条件开始 -->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
    <legend>查询条件</legend>
</fieldset>
<form class="layui-form" >
    <div class="layui-form-item">
        <div class="layui-inline">
            <label class="layui-form-label">角色名称:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="roleName" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入角色名称" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">角色描述:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="roleDesc" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入角色描述" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">是否可用:</label>
            <div class="layui-input-inline">
                <input type="radio" name="available" id="available_on" value="1"  title="可用">
                <input type="radio" name="available" id="available_off" value="0" title="不可用">
            </div>
        </div>
        <div class="layui-inline">
            <button class="layui-btn layui-btn-normal layui-btn-radius"  lay-submit lay-filter="formDemo">查询</button>
            <button type="reset" class="layui-btn layui-btn-warm layui-icon layui-icon-refresh layui-btn-radius layui-btn-sm">重置
            </button>
        </div>
    </div>
</form>


<table id="roleTable" lay-filter="roleTable"></table>

<script id="toolbarRole" type="text/html">
    <div class="layui-btn-container">
        <button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="roleAdd">添加</button>
        <button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="roleDelChk">批量删除</button>
    </div>
</script>

<script id="barRole" type="text/html">
    <a class="layui-btn layui-btn-xs layui-btn-radius" lay-event="edit">编辑</a>
    <a class="layui-btn layui-btn-xs layui-btn-radius" lay-event="selRoleMenu">分配角色</a>
    <a class="layui-btn layui-btn-danger layui-btn-xs " lay-event="del">删除</a>
</script>

<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding: 20px" id="saveOrUpdateDiv">
    <form class="layui-form" lay-filter="dataFrm" id="dataFrm">

        <div class="layui-form-item">
            <label class="layui-form-label">角色名称:</label>
            <div class="layui-input-block">
                <input type="hidden" name="roleId">
                <input type="text" name="roleName" placeholder="请输入角色名称" autocomplete="off" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">角色描述:</label>
            <div class="layui-input-block">
                <input type="text" name="roleDesc" placeholder="请输入角色描述" autocomplete="off" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">是否可用:</label>
                <div class="layui-input-inline">
                    <input type="radio" name="available" value="1" checked title="可用">
                    <input type="radio" name="available" value="0" title="不可用">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;padding-right: 120px">
                <button type="button"
                        class="layui-btn layui-btn-normal layui-btn-md layui-icon layui-icon-release layui-btn-radius"
                        lay-filter="doSubmit" lay-submit="">提交
                </button>
                <button type="reset"
                        class="layui-btn layui-btn-warm layui-btn-md layui-icon layui-icon-refresh layui-btn-radius">重置
                </button>
            </div>
        </div>
    </form>
</div>
<!-- 添加和修改的弹出层结束 -->
<%--分配角色开始--%>
<div style="display: none;padding: 20px" id="selRoleMenuDiv">
    <ul id="menuTree" class="dtree" data-id="0" style="width: 100%;"></ul>
</div>
<%--分配角色结束--%>
<script src="/layui/layui.js"></script>
<script>
    var roleTable
    var index
    var url
    layui.extend({
        dtree: '/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
    }).use(['table','form','layer','jquery','dtree'], function() {
        var table = layui.table
        var form = layui.form
        var layer = layui.layer
        var $ = layui.jquery
        var dtree=layui.dtree

        // 初始table
        roleTable = table.render({
            elem: "#roleTable"
            , url: "/role/findRole"
            , page: {limit: 5, limits: [5, 10, 15]}
            , cellMinWidth: 80
            , toolbar: '#toolbarRole'
            , cols: [[ //表头
                {type: 'checkbox', fixed: 'left'}
                , {field: 'roleId', title: '角色ID', fixed: 'center'}
                , {field: 'roleName', title: '角色名称', width: 120, fixed: 'center'}
                , {field: 'roleDesc', title: '角色描述', width: 200, fixed: 'center'}
                , {
                    field: 'available', title: '是否可用', fixed: 'center', templet: function (data) {
                        return data.available == 1 ? "可用" : "<font color=red >不可用</font>"
                    }
                }
                , {fixed: 'right', title: '操作', toolbar: '#barRole', width: 250}
            ]]
        })


        // 查询
        form.on("submit(formDemo)", function (data) {
            console.info(data+"1111")
            roleTable.reload({
                url: "/role/findRole"
                , where: {
                    'roleName': data.field.roleName
                    , 'roleDesc':data.field.roleDesc
                    ,'available':data.field.available

                }
                , page: {
                    curr: 1
                }
            })
            return false;
        })
        // 头部工具栏添加事件
        table.on('toolbar(roleTable)',function(obj) {
            if(obj.event == "roleAdd"){ // 点击新增按钮执行的内容
                roleAdd()
            }else if(obj.event=="roleDelChk"){
                roleDelChk(obj)
            }
        })
        //监听行工具事件
        table.on('tool(roleTable)', function(obj){
            var data = obj.data
            if(obj.event == "edit"){
                menuUpdate(data)
            }else  if(obj.event == "del"){
                del(data)
            }else if(obj.event=="selRoleMenu"){
                selRoleMenu(data)
            }
        })
        function selRoleMenu(data) {
            index = layer.open({
                type:1
                , title:"分配"+data.roleName+"角色"
                , content:$("#selRoleMenuDiv")
                ,area :['400px','500px']
                , btn:['<div class="layui-icon layui-icon-release">确认分配</div>'
                    ,'<div class="layui-icon layui-icon-close">取消分配</div>']
                ,btnAlign:'c'
                ,success:function () {
                    // 给下拉数赋值
                    dtree.render({
                        elem: "#menuTree",
                        url: "/role/roleTreeJson?roleId="+data.roleId // 使用url加载（可与data加载同时存在）
                        , dataStyle:"layuiStyle"//使用layui风格的数据格式
                        , response:{message:"msg",statusCode:0}  //修改response中返回数据的定义
                        , checkbar : true
                        , checkbarType:"all"
                        , checkbarData:"choose"
                    });
                }
                , yes : function(){
                    // 获取菜单数中选中的nodes
                    var nodes = dtree.getCheckbarNodesParam("menuTree");
                    // 获取角色id
                    var roleId = data.roleId
                    var param = "roleId="+roleId

                    // 循环选中的内容nodes
                    $.each(nodes,function(i,item){
                        param += "&ids=" +item.nodeId
                    })
                    // A=valueA&B=valueB&B=valueB
                    // 把数据保存到数据库
                    $.get("/role/saveRoleMenu?"+param,function (r) {
                        layer.msg(r.msg)
                    })
                    layer.close(index)
                }
            })

        }
        function roleDelChk(obj) {
            var checkStatus=table.checkStatus(obj.config.id);
            var data=checkStatus.data
            if(data.length==0){
                layer.msg("请至少选择一个数据")
            }else {
                var roleIds=new Array()
                $.each(data,function (index,item) {
                    roleIds.push(item.roleId)
                })
                layer.confirm("你确定要删除"+data.length+"条数据么",function (ind) {
                    $.post("/role/roleDelChk",{"roleIds":roleIds},function (r) {
                        layer.msg(r.msg)
                        roleTable.reload()
                    })
                    layer.close(ind)
                })
            }
        }
        function del(data){

            $.post("/role/chkRoleUserMenu",{"roleId":data.roleId},function (r) {
                if(r.code>0){
                    alert("该角色"+data.roleName+"有关联数据。")
                }
            })
            layer.confirm("您确定要删除"+ data.roleName +"数据么",function(ind){

                        $.post("/role/delRole", {"roleId":data.roleId} ,function(d) {
                            layer.msg(d.msg)
                            // 刷新table数据
                            roleTable.reload()

                        })
                layer.close(ind)
            })


        }
        function menuUpdate(data) {
            index =  layer.open({
                type:1
                , title:"修改菜单"
                , content:$("#saveOrUpdateDiv")
                , area : ['800px', '440px']
                , success:function(layero, index) {
                    form.val("dataFrm",data)
                    url="/role/updateRole"
                }
            })
        }
        function roleAdd() {
            // 弹出框
            index =  layer.open({
                type:1 //
                , title:"添加菜单"
                , content:$("#saveOrUpdateDiv")
                , area : ['800px', '440px']
                , success:function(layero, index) {
                    // 页面数据要清除
                    $("#dataFrm")[0].reset()
                    url="/role/addRole"
                }
            })

        }
        // form表达提交
        form.on("submit(doSubmit)",function() {
            layer.confirm("您确定要提交该数据么",function(ind){
                $.post(url,$("#dataFrm").serialize(),function(data) {
                    layer.msg(data.msg)
                    layer.close(index)
                    roleTable.reload()
                })
                layer.close(ind)
            })





    })
    })

</script>
</body>
</html>
